<template>
  <PageWrapper
      :title="`用户` + userInfo.username + `的资料`"
      content="这是用户资料详情页面。本页面仅用于演示相同路由在tab中打开多个页面并且显示不同的数据"
      contentBackground
      @back="goBack"
  >
    <template #extra>
      <a-button type="primary" danger> 禁用账号</a-button>
      <a-button type="primary"> 修改密码</a-button>
    </template>
    <template #footer>
      <a-tabs default-active-key="detail" v-model:activeKey="currentKey">
        <a-tab-pane key="detail" tab="用户资料" />
        <a-tab-pane key="logs" tab="操作日志" />
      </a-tabs>
    </template>
    <div class="pt-4 m-4 desc-wrap">
      <template v-if="currentKey == 'detail'">
        <div v-for="i in 10" :key="i">这是用户 {{ userInfo.username }} 资料Tab</div>
      </template>
      <template v-if="currentKey == 'logs'">
        <div v-for="i in 10" :key="i">这是用户 {{ userInfo.username }} 操作日志Tab</div>
      </template>
    </div>
  </PageWrapper>
</template>

<script>
import { defineComponent, ref, onMounted } from "vue";
import { useRoute } from "vue-router";
import { PageWrapper } from "/@/components/Page";
import { useGo } from "/@/hooks/web/usePage";
import { useTabs } from "/@/hooks/web/useTabs";
import { Tabs } from "ant-design-vue";
import { getUserInfoById } from "/@/api/system/account";

export default defineComponent({
  name: "AccountDetail",
  components: { PageWrapper, ATabs: Tabs, ATabPane: Tabs.TabPane },
  setup() {
    const route = useRoute();
    const go = useGo();
    // 此处可以得到用户ID
    const userId = ref(route.params?.id);
    const currentKey = ref("detail");
    const { setTitle } = useTabs();
    // TODO
    // 本页代码仅作演示，实际应当通过userId从接口获得用户的相关资料
    const userInfo = ref({});
    getUserInfoById(userId.value).then(res => userInfo.value = res);

    // 设置Tab的标题（不会影响页面标题）
    setTitle(`用户详情（ID=${userId.value}）`);

    // 页面左侧点击返回链接时的操作
    function goBack() {
      // 本例的效果时点击返回始终跳转到账号列表页，实际应用时可返回上一页
      go("/system/account");
    }

    return { userId, currentKey, goBack, userInfo };
  }

});
</script>

<style></style>
